# This Page Is Inserted by IFW Operations and is not a part of the Official Record

## **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images may include (but are not limited to):

- BLACK BORDERS
- TEXT CUT OFF AT TOP, BOTTOM OR SIDES
- FADED TEXT
- ILLEGIBLE TEXT
- SKEWED/SLANTED IMAGES
- COLORED PHOTOS
- BLACK OR VERY BLACK AND WHITE DARK PHOTOS
- GRAY SCALE DOCUMENTS

### IMAGES ARE BEST AVAILABLE COPY.

As rescanning documents will not correct images, please do not report the images to the Image Problem Mailbox.

#### AMENDMENTS TO THE CLAIMS

The listing of claims will replace all prior versions, and listings, of claims in the application:

#### **Listing of Claims**

- 1. (Currently Amended) A processor system comprising: a processor,
- a first memory, being of a random access memory type,
- a second memory, being of a random access memory type,

memory allocation means for allocation of data of a load module of said second memory to said first memory, said load module comprising variable/record data and/or instruction data,

an execution profiling section for providing execution data concerning behaviour of programs executed in the processor system, continuously or intermittently, whereby the operation of said means for memory allocation is software run-time updated based on said execution data, said execution profiling section in turn comprising at least one means for measuring the performance characteristics of part entities parts of said load module,

whereby said memory allocation means is arranged for allocation of selected part entities parts of said load module to said first memory.

- 2. (Currently Amended) The processor system according to claim 1, wherein at least one of said selected part entities parts is an individual variable/record, instructions of a program routine or instructions of a basic block, whereby basic block being defined as a straight sequence of instructions with the beginning and end as the sole enter and exit point, respectively.
- 3. (Original) The processor system according to claim 1, wherein said execution profiling section is arranged to select programs, for which said execution data is to be provided, according to internal information of an operating system.

Amendment - PAGE 2 of 17

07/06/2004 12:42

- (Original) The processor system according to claim 3, wherein said 4 internal information comprises information about the priority of the program and/or whether the program is executed as a maintenance or background job.
- 5. (Currently Amended) The processor system according to claim 3, wherein said internal information comprises information about sizes of said part entitles parts of said load module.
- (Currently Amended) The processor system according to claim 1, wherein 6. said execution profiling section comprises means for measuring the performance for a first type of data, variable/record data or instruction data, and in that said means for memory allocation comprises means for selecting part entities parts of a load module of both types of data as candidates for being allocated to said first memory, based on said measured performance of said first type of data.
- (Currently Amended) The processor system according to claim 1, wherein 7. said means for measuring the performance characteristics comprises means for measuring the number of accesses to part entities parts of said load module.
- 8. (Currently Amended) The processor system according to claim 7, wherein said means for measuring the performance characteristics comprises means for measuring the number of read accesses to part entities parts of said load module.
- 9. (Currently Amended) The processor system according to claim 1, wherein said means for measuring the performance characteristics comprises means for measuring the waiting time for access to part entities parts of said load module.
- 10. (Original) The processor system according to claim 7, wherein said means for measuring the performance characteristics comprises a hardware counter.

- 11. (Currently Amended) The processor system according to claim 10, wherein said execution profiling section further comprises a timer[[,]] for calibration of measured performance characteristics.
- 12. (Original) The processor system according to claim 9, wherein said means for measuring the performance characteristics comprises a hardware counter.
- 13. (Original) The processor system according to claim 12, wherein said execution profiling section further comprises a timer, for calibration of measured performance characteristics.
- 14. (Original) The processor system according to claim 7, wherein said means for measuring the number of accesses is implemented by code instrumentation.
- 15. (Original) The processor system according to claim 9, wherein said means for measuring the number of accesses is implemented by code instrumentation.
- 16. (Original) The processor system according to claim 7, wherein said means for measuring the number of accesses is implemented in an emulator or virtual machine.
- 17. (Original) The processor system according to claim 9, wherein said means for measuring the number of accesses is implemented in an emulator or virtual machine.
- 18. (Original) The processor system according claim 1, wherein said means for memory allocation is arranged to read a link table.
- 19. (Original) The processor system according to claim 18, wherein at least a part of said link table is allocated to said first memory.

- 20. (Currently Amended) The processor system according to claim [[14]] <u>18</u>, wherein said link table supports run-time linking.
- 21. (Original) The processor system according to claim 1, wherein said first memory is connected to said processor by a dedicated bus.
- 22. (Original) The processor system according to claim 1, wherein said first memory is implemented in a memory area located on the processor chip.
- 23. (Original) The processor system according to claim 1, wherein said first memory comprises at least one static random access memory.
- 24. (Original) The processor system according to claim 1, further comprising a third memory acting as a first level cache memory, whereby said first memory constitutes a second level cache memory.
- 25. (Currently Amended) The processor system according to claim 1, wherein said means for memory allocation operates according to a first algorithm for modifying said allocation data upon start, restart, or software change of the processor system, and according to a second algorithm for modifying said allocation data at a later occasion during steady-state operation of the system.
- 26. (Currently Amended) The processor system according to claim [[21]] <u>25</u>, wherein said first algorithm is substantially based on information about sizes of part entities parts of said load module.
- 27. (Original) The processor system according to claim 1, wherein the data allocated to said first memory further comprises reference data

- 28. (Original) The processor system according to claim 1, wherein said first memory is organised as a combined memory for at least two of the following types: variables or records, instructions, and tables.
- 29. (Original) The processor system according to claim 1, wherein said first memory is organised as a split memory for the following types: variables or records, instructions, and tables.
- 30. (Currently Amended) A method for memory handling in a processor system, comprising the steps of:

providing allocation data associated with a first set of data of a load module for allocation to a first memory, being of a random access memory type, from a second memory, being of a random access memory type, said load module comprising variable/record data and/or instruction data;

if said first set of data is allocated to [[a]] said first memory, accessing said first memory for said first set of data;

providing, continuously or intermittently, execution data concerning behaviour of programs executed in said processor system, said step of providing execution data in turn comprising the step of measuring the performance characteristics of part entities parts of said load module;

modifying said allocation data by software in a run-time manner, based on said execution data; and

whereby said allocation data is arranged for allocation of selected part entities parts of said load module to said first memory.

31. (Currently Amended) The method according to claim 30, wherein at least one of said selected part entities parts is an individual variable/record, instructions of a program routine or instructions of a basic block, whereby basic block being defined as a straight sequence of instructions with the beginning and end as the sole enter and exit point, respectively.

- 32. (Original) The method according to claim 30, wherein said step of providing execution data provides execution data concerning behaviours of programs, selected according to internal information of an operating system.
- 33. (Original) The method according to claim 32, wherein said internal information comprises information about the priority of the program and/or if the program is executed as a maintenance or background job.
- 34. (Currently Amended) The method according to claim 32, wherein said internal information comprises information about sizes of said part entities parts of said load module.
- 35. (Currently Amended) The method according to claim 30, wherein said step of measuring the performance characteristics comprises the steps of: measuring the performance for a first type of data, variable/record data or instruction data, selecting part entities parts of a load module of both types of data as candidates for being allocated to said first memory, based on said measured performance of said first type of data.
- 36. (Currently Amended) The method according to claim 30, wherein said step of measuring the performance characteristics comprises the steps of measuring the number of accesses to <u>part entities parts</u> of said load module.
- 37. (Currently Amended) The method according to claim 36, wherein said step of measuring the performance characteristics comprises the steps of measuring the number of read accesses to part entities parts of said load module.
- 38. (Currently Amended) The method according to claim 30, wherein said step of measuring the performance characteristics comprises the steps of measuring the waiting time for access to part entities parts of said load module.

#### 39. (Canceled)

- 40. (Original) The method according to claim 30, wherein said step of providing allocation data comprises the step of reading of link tables.
- 41. (Original) The method according to claim 40, wherein said link table supports run-time linking.
- 42. (Original) The method according to claim 30, wherein said step of modification favours allocation of data having the highest measured performance importance per time unit to said first memory.
- 43. (Original) The method according to claim 30, wherein the data allocated to said first memory further comprises reference data.
- 44. (Original) The method according to claim 30, further comprising the step of using a first algorithm for modifying said allocation data upon start or restart of the processor system, and switching to a second algorithm for modifying said allocation data at a later occasion.
- 45. (Currently Amended) The method according to claim 44, wherein said first algorithm is substantially based on information about sizes of part entities parts of said load module.
- 46. (Currently Amended) The method according to claim 30, further comprising the step of packing the content of a second memory from which data is [[are]] re-allocated to said first memory, said packing occurring periodically and/or after larger large re-allocations of data.
- 47. (Original) The method according to claim 30, further comprising the step of run-time updating of said software controlling said modification of said allocation data.

Amendment - PAGE 8 of 17 EUS/J/P/04-8772

- 48. (Currently Amended) A processor system comprising:
- a processor,
- a first memory being of a random access memory type,
- a second memory being of a random access memory type,

memory allocation means for allocation of data of a load module of said second memory to said first memory, said load module comprising variable/record data and/or instruction data, said memory allocation section being arranged for allocation of selected part entities parts of said load module to said first memory, said selection being based on internal information of an operating system.

- 49. (Currently Amended) The processor system according to claim 48, wherein at least one of said selected part entities parts is an individual variable/record, instructions of a program routine or instructions of a basic block, whereby basic block being defined as a straight sequence of instructions with the beginning and end as the sole enter and exit point, respectively.
- 50. (Original) The processor system according to claim 48, wherein said internal information comprises information about the priority of the program and/or information of whether the program is executed as a maintenance or background job.
- 51. (Currently Amended) The processor system according to claim 48, wherein said internal information comprises information about sizes of said part entities parts of said load module.
- 52. (Currently Amended) A method for memory handling in a processor system, comprising the steps of:

allocating data associated with a first set of data of a load module into a first memory, being of a random access memory type, from a second memory, being of a random access memory type, said load module comprising variable/record data and/or instruction data, said step of allocating data in turn comprising the step of providing

internal Information of an operating system regarding part-entities parts of said load module, whereby the allocation of data is performed on selected part entities parts; and accessing said first memory for said first set of data.

- 53. (Currently Amended) The method according to claim 52, wherein at least one of said selected part entities parts is an individual variable/record, instructions of a program routine or instructions of a basic block, whereby basic block being defined as a straight sequence of instructions with the beginning and end as the sole enter and exit point, respectively.
- 54. (Original) The method according to claim 52, wherein said internal information comprises information about the priority of the program and/or if the program is executed as a maintenance or background job.
- 55. (Currently Amended) The method according to claim 52, wherein said internal information comprises information about sizes of said part entities parts of said load module.